Code Context
" alt="<div class="festival-pick"><img src="/images/FestivalPickUsers/image/<?= $festival_pick->festival_pick_user->id?>" alt="<?= $festival_pick->festival_pick_user->name; ?>" />
$templateFile = '/home/mifo/public_html/templates/Films/info.php'
$dataForView = [
'film' => object(Cake\ORM\Entity) {
'id' => (int) 1245,
'poster' => null,
'visible' => true,
'spotlight' => false,
'title' => 'Song Lang',
'genre' => 'Crime, Drama, Gay, Romance, Suspense',
'category' => '',
'streaming_category' => null,
'venue' => 'The Classic Gateway Theatre',
'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304',
'ticket_link' => 'https://tickets.completeticketsolutions.com/OSFF/Online/seatSelect.asp?BOset::WSmap::seatmap::performance_ids=3EB8C6DC-4541-47D2-A6F7-92539ABA69B5',
'virtual_ticket_link' => null,
'party_ticket_link' => null,
'in_theaters' => true,
'datetime' => object(Cake\I18n\FrozenTime) {},
'has_endtime' => false,
'endtime' => null,
'is_streaming' => false,
'streaming_start' => null,
'streaming_end' => null,
'event_id' => null,
'director' => 'Leon Le',
'runtime' => '90 mins',
'language' => 'Vietnamese w/ English Subtitles',
'country' => 'Vietnam',
'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/lmL5jupLHEs" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>',
'twitter_link' => null,
'facebook_link' => '',
'synopsis' => 'An unlikely bond develops between hunky, brooding and tough debt collector Dung and Linh Phung, a charismatic young opera singer from a struggling Cai-luong troupe (traditional Vietnamese opera). The two meet when Dung comes to forcefully collect a debt from the opera troupe, but when their paths cross again, a friendship - and then more - develops, awakening surprising, tender feelings in both men. Their story, too, soon scales operatic heights. Director Leon Le has delivered a rich drama, a smoldering relationship between two apparent opposites set against the backdrop of a gorgeous, fading art form. Set in 1980's Saigon, <i>Song Lang</i> is a gritty underworld noir hiding a tender, romantic heart.',
'logline' => null,
'image' => null,
'thumbnail' => null,
'additional_info' => '',
'preceded_by' => '',
'community_partner' => null,
'community_partner_link' => '',
'community_partner_enabled' => false,
'community_partner2' => null,
'community_partner_link2' => '',
'community_partner_enabled2' => false,
'sponsor' => null,
'sponsor_link' => '',
'sponsor_enabled' => false,
'year' => null,
'city' => 'ftl',
'series' => 'Festival',
'event' => null,
'film_header_images' => [
[maximum depth reached]
],
'festival_pick_talent' => [[maximum depth reached]],
'festival_picks' => [
[maximum depth reached]
],
'[new]' => false,
'[accessible]' => [
[maximum depth reached]
],
'[dirty]' => [[maximum depth reached]],
'[original]' => [[maximum depth reached]],
'[virtual]' => [[maximum depth reached]],
'[hasErrors]' => false,
'[errors]' => [[maximum depth reached]],
'[invalid]' => [[maximum depth reached]],
'[repository]' => 'Films'
},
'suggested_films' => [
(int) 0 => object(Cake\ORM\Entity) {},
(int) 1 => object(Cake\ORM\Entity) {}
],
'title' => 'OUTshine Film Festival - Song Lang',
'presenting_sponsors' => object(Cake\ORM\Query) {
'(help)' => 'This is a Query object, to get the results execute or iterate it.',
'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)',
'params' => [
[maximum depth reached]
],
'defaultTypes' => [
[maximum depth reached]
],
'decorators' => (int) 0,
'executed' => false,
'hydrate' => true,
'buffered' => true,
'formatters' => (int) 0,
'mapReducers' => (int) 0,
'contain' => [[maximum depth reached]],
'matching' => [[maximum depth reached]],
'extraOptions' => [[maximum depth reached]],
'repository' => object(Cake\ORM\Table) {}
},
'sponsors_loop' => object(Cake\ORM\Query) {
'(help)' => 'This is a Query object, to get the results execute or iterate it.',
'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)',
'params' => [
[maximum depth reached]
],
'defaultTypes' => [
[maximum depth reached]
],
'decorators' => (int) 0,
'executed' => false,
'hydrate' => true,
'buffered' => true,
'formatters' => (int) 0,
'mapReducers' => (int) 0,
'contain' => [[maximum depth reached]],
'matching' => [[maximum depth reached]],
'extraOptions' => [[maximum depth reached]],
'repository' => object(Cake\ORM\Table) {}
},
'skyscrapers' => object(Cake\ORM\Query) {
'(help)' => 'This is a Query object, to get the results execute or iterate it.',
'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)',
'params' => [
[maximum depth reached]
],
'defaultTypes' => [
[maximum depth reached]
],
'decorators' => (int) 0,
'executed' => false,
'hydrate' => true,
'buffered' => true,
'formatters' => (int) 0,
'mapReducers' => (int) 0,
'contain' => [[maximum depth reached]],
'matching' => [[maximum depth reached]],
'extraOptions' => [[maximum depth reached]],
'repository' => object(Cake\ORM\Table) {}
},
'ticket_link' => '',
'banners' => object(Cake\ORM\Query) {
'(help)' => 'This is a Query object, to get the results execute or iterate it.',
'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)',
'params' => [
[maximum depth reached]
],
'defaultTypes' => [
[maximum depth reached]
],
'decorators' => (int) 0,
'executed' => false,
'hydrate' => true,
'buffered' => true,
'formatters' => (int) 0,
'mapReducers' => (int) 0,
'contain' => [[maximum depth reached]],
'matching' => [[maximum depth reached]],
'extraOptions' => [[maximum depth reached]],
'repository' => object(Cake\ORM\Table) {}
},
'festival' => 'mia'
]
$film = object(Cake\ORM\Entity) {
'id' => (int) 1245,
'poster' => null,
'visible' => true,
'spotlight' => false,
'title' => 'Song Lang',
'genre' => 'Crime, Drama, Gay, Romance, Suspense',
'category' => '',
'streaming_category' => null,
'venue' => 'The Classic Gateway Theatre',
'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304',
'ticket_link' => 'https://tickets.completeticketsolutions.com/OSFF/Online/seatSelect.asp?BOset::WSmap::seatmap::performance_ids=3EB8C6DC-4541-47D2-A6F7-92539ABA69B5',
'virtual_ticket_link' => null,
'party_ticket_link' => null,
'in_theaters' => true,
'datetime' => object(Cake\I18n\FrozenTime) {},
'has_endtime' => false,
'endtime' => null,
'is_streaming' => false,
'streaming_start' => null,
'streaming_end' => null,
'event_id' => null,
'director' => 'Leon Le',
'runtime' => '90 mins',
'language' => 'Vietnamese w/ English Subtitles',
'country' => 'Vietnam',
'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/lmL5jupLHEs" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>',
'twitter_link' => null,
'facebook_link' => '',
'synopsis' => 'An unlikely bond develops between hunky, brooding and tough debt collector Dung and Linh Phung, a charismatic young opera singer from a struggling Cai-luong troupe (traditional Vietnamese opera). The two meet when Dung comes to forcefully collect a debt from the opera troupe, but when their paths cross again, a friendship - and then more - develops, awakening surprising, tender feelings in both men. Their story, too, soon scales operatic heights. Director Leon Le has delivered a rich drama, a smoldering relationship between two apparent opposites set against the backdrop of a gorgeous, fading art form. Set in 1980's Saigon, <i>Song Lang</i> is a gritty underworld noir hiding a tender, romantic heart.',
'logline' => null,
'image' => null,
'thumbnail' => null,
'additional_info' => '',
'preceded_by' => '',
'community_partner' => null,
'community_partner_link' => '',
'community_partner_enabled' => false,
'community_partner2' => null,
'community_partner_link2' => '',
'community_partner_enabled2' => false,
'sponsor' => null,
'sponsor_link' => '',
'sponsor_enabled' => false,
'year' => null,
'city' => 'ftl',
'series' => 'Festival',
'event' => null,
'film_header_images' => [
(int) 0 => object(Cake\ORM\Entity) {},
(int) 1 => object(Cake\ORM\Entity) {},
(int) 2 => object(Cake\ORM\Entity) {},
(int) 3 => object(Cake\ORM\Entity) {}
],
'festival_pick_talent' => [],
'festival_picks' => [
(int) 0 => object(Cake\ORM\Entity) {},
(int) 1 => object(Cake\ORM\Entity) {}
],
'[new]' => false,
'[accessible]' => [
'*' => true
],
'[dirty]' => [],
'[original]' => [],
'[virtual]' => [],
'[hasErrors]' => false,
'[errors]' => [],
'[invalid]' => [],
'[repository]' => 'Films'
}
$suggested_films = [
(int) 0 => object(Cake\ORM\Entity) {
'id' => (int) 2002,
'poster' => null,
'visible' => true,
'spotlight' => false,
'title' => 'The Divine Tragedy (La Divina Tragedia)',
'genre' => 'Comedy, Drama, Gay',
'category' => '',
'streaming_category' => '',
'venue' => 'Paradigm Cinemas: Gateway Fort Lauderdale',
'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304',
'ticket_link' => 'https://outshinespring2026.eventive.org/schedule/69c6cb71fe9976d6a967cc2a',
'virtual_ticket_link' => 'https://watch.eventive.org/outshinespring2026/play/69c6da7f654a19ba46364dc8',
'party_ticket_link' => '',
'in_theaters' => true,
'datetime' => object(Cake\I18n\FrozenTime) {},
'has_endtime' => false,
'endtime' => null,
'is_streaming' => true,
'streaming_start' => object(Cake\I18n\FrozenTime) {},
'streaming_end' => object(Cake\I18n\FrozenTime) {},
'event_id' => null,
'director' => 'Sergio Tovar Velarde',
'runtime' => '102 Minutes',
'language' => 'Spanish',
'country' => 'Mexico, 2025',
'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/YSmjk11Ft8E?si=JDS_MdLknzEbUatB" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe>',
'twitter_link' => null,
'facebook_link' => '',
'synopsis' => 'After 25 years together, Cristian’s life is upended when his long-term relationship ends abruptly. Forced to abandon his life of luxury, he moves in with his half-brother Roy, a much younger, openly gay man whose chaotic lifestyle clashes with Cristian’s need for order. As the two opposites navigate cramped quarters, old wounds, and new beginnings, they must learn to coexist—and maybe even support each other—in ways neither expected. The Divine Tragedy is a sharply funny, yet tender dramedy about midlife reinvention, unexpected brotherhood, and the messy, beautiful process of starting over when everything you knew falls apart.',
'logline' => 'When Cristian’s decades-long relationship ends, he’s forced to move in with his chaotic, younger gay half-brother, Roy. As opposites collide under one roof, both men must confront past regrets and unexpected bonds in a search for renewal.',
'image' => null,
'thumbnail' => null,
'additional_info' => '',
'preceded_by' => '',
'community_partner' => resource,
'community_partner_link' => 'https://preventionx.org/',
'community_partner_enabled' => true,
'community_partner2' => null,
'community_partner_link2' => '',
'community_partner_enabled2' => false,
'sponsor' => null,
'sponsor_link' => '',
'sponsor_enabled' => false,
'year' => null,
'city' => 'ftl',
'series' => 'Spring Edition',
'film_header_images' => [
[maximum depth reached]
],
'[new]' => false,
'[accessible]' => [
[maximum depth reached]
],
'[dirty]' => [[maximum depth reached]],
'[original]' => [[maximum depth reached]],
'[virtual]' => [[maximum depth reached]],
'[hasErrors]' => false,
'[errors]' => [[maximum depth reached]],
'[invalid]' => [[maximum depth reached]],
'[repository]' => 'Films'
},
(int) 1 => object(Cake\ORM\Entity) {
'id' => (int) 1977,
'poster' => null,
'visible' => true,
'spotlight' => false,
'title' => 'CLOSING NIGHT FILM & PARTY: We’ll Find Happiness (On Sera Heureux)',
'genre' => 'Drama, Gay, Romance',
'category' => '',
'streaming_category' => '',
'venue' => 'Savor Cinema',
'venue_address' => '503 SE 6th St, Fort Lauderdale, FL 33301',
'ticket_link' => '',
'virtual_ticket_link' => '',
'party_ticket_link' => 'https://outshinespring2026.eventive.org/schedule/69c6cf7b8a7ebad6fa7ae8d2',
'in_theaters' => true,
'datetime' => object(Cake\I18n\FrozenTime) {},
'has_endtime' => false,
'endtime' => null,
'is_streaming' => false,
'streaming_start' => object(Cake\I18n\FrozenTime) {},
'streaming_end' => object(Cake\I18n\FrozenTime) {},
'event_id' => null,
'director' => 'Lea Pool',
'runtime' => '102 minutes',
'language' => 'French, English, Farsi, Arabic',
'country' => 'Canada, 2025',
'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/Nj7DjOGdnIs?si=nfYl7MW3yL-bfpyH" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe>',
'twitter_link' => null,
'facebook_link' => '',
'synopsis' => 'Saad, a young Moroccan exile in Quebec with secrets of his own, will do anything to save the man he loves, Reza, an Iranian refugee facing deportation and likely death. In a desperate gamble, Saad attempts to seduce Laurent, a gorgeous, high-ranking Ministry of Immigration spokesperson, triggering a chain of events that are as intimate as they are political. Traversing Iran, Spain, France, and Canada in a stylish fury, We’ll Find Happiness crafts a rare, powerful, and timely portrait of LGBTQ+ refugees, blending passion, sacrifice, and the relentless pursuit of freedom.',
'logline' => 'A Moroccan exile risks everything to save his deportation-threatened lover, sparking a tense and deeply personal struggle that intertwines love, politics, and the fight for freedom.',
'image' => null,
'thumbnail' => null,
'additional_info' => '',
'preceded_by' => '',
'community_partner' => resource,
'community_partner_link' => 'http://eqfl.org',
'community_partner_enabled' => true,
'community_partner2' => resource,
'community_partner_link2' => 'https://www.latinossalud.org/',
'community_partner_enabled2' => true,
'sponsor' => null,
'sponsor_link' => '',
'sponsor_enabled' => false,
'year' => null,
'city' => 'ftl',
'series' => 'Spring Edition',
'film_header_images' => [
[maximum depth reached]
],
'[new]' => false,
'[accessible]' => [
[maximum depth reached]
],
'[dirty]' => [[maximum depth reached]],
'[original]' => [[maximum depth reached]],
'[virtual]' => [[maximum depth reached]],
'[hasErrors]' => false,
'[errors]' => [[maximum depth reached]],
'[invalid]' => [[maximum depth reached]],
'[repository]' => 'Films'
}
]
$title = 'OUTshine Film Festival - Song Lang'
$presenting_sponsors = object(Cake\ORM\Query) {
'(help)' => 'This is a Query object, to get the results execute or iterate it.',
'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)',
'params' => [
':c0' => [
[maximum depth reached]
],
':c1' => [
[maximum depth reached]
]
],
'defaultTypes' => [
'Sponsors__id' => 'integer',
'Sponsors.id' => 'integer',
'id' => 'integer',
'Sponsors__link_url' => 'string',
'Sponsors.link_url' => 'string',
'link_url' => 'string',
'Sponsors__image' => 'binary',
'Sponsors.image' => 'binary',
'image' => 'binary',
'Sponsors__hidden' => 'boolean',
'Sponsors.hidden' => 'boolean',
'hidden' => 'boolean',
'Sponsors__category' => 'string',
'Sponsors.category' => 'string',
'category' => 'string',
'Sponsors__description' => 'text',
'Sponsors.description' => 'text',
'description' => 'text',
'Sponsors__city' => 'string',
'Sponsors.city' => 'string',
'city' => 'string',
'Sponsors__sort' => 'integer',
'Sponsors.sort' => 'integer',
'sort' => 'integer'
],
'decorators' => (int) 0,
'executed' => false,
'hydrate' => true,
'buffered' => true,
'formatters' => (int) 0,
'mapReducers' => (int) 0,
'contain' => [],
'matching' => [],
'extraOptions' => [],
'repository' => object(Cake\ORM\Table) {}
}
$sponsors_loop = object(Cake\ORM\Query) {
'(help)' => 'This is a Query object, to get the results execute or iterate it.',
'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)',
'params' => [
':c0' => [
[maximum depth reached]
],
':c1' => [
[maximum depth reached]
]
],
'defaultTypes' => [
'Sponsors__id' => 'integer',
'Sponsors.id' => 'integer',
'id' => 'integer',
'Sponsors__link_url' => 'string',
'Sponsors.link_url' => 'string',
'link_url' => 'string',
'Sponsors__image' => 'binary',
'Sponsors.image' => 'binary',
'image' => 'binary',
'Sponsors__hidden' => 'boolean',
'Sponsors.hidden' => 'boolean',
'hidden' => 'boolean',
'Sponsors__category' => 'string',
'Sponsors.category' => 'string',
'category' => 'string',
'Sponsors__description' => 'text',
'Sponsors.description' => 'text',
'description' => 'text',
'Sponsors__city' => 'string',
'Sponsors.city' => 'string',
'city' => 'string',
'Sponsors__sort' => 'integer',
'Sponsors.sort' => 'integer',
'sort' => 'integer'
],
'decorators' => (int) 0,
'executed' => false,
'hydrate' => true,
'buffered' => true,
'formatters' => (int) 0,
'mapReducers' => (int) 0,
'contain' => [],
'matching' => [],
'extraOptions' => [],
'repository' => object(Cake\ORM\Table) {}
}
$skyscrapers = object(Cake\ORM\Query) {
'(help)' => 'This is a Query object, to get the results execute or iterate it.',
'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)',
'params' => [
':c0' => [
[maximum depth reached]
],
':c1' => [
[maximum depth reached]
]
],
'defaultTypes' => [
'Sponsors__id' => 'integer',
'Sponsors.id' => 'integer',
'id' => 'integer',
'Sponsors__link_url' => 'string',
'Sponsors.link_url' => 'string',
'link_url' => 'string',
'Sponsors__image' => 'binary',
'Sponsors.image' => 'binary',
'image' => 'binary',
'Sponsors__hidden' => 'boolean',
'Sponsors.hidden' => 'boolean',
'hidden' => 'boolean',
'Sponsors__category' => 'string',
'Sponsors.category' => 'string',
'category' => 'string',
'Sponsors__description' => 'text',
'Sponsors.description' => 'text',
'description' => 'text',
'Sponsors__city' => 'string',
'Sponsors.city' => 'string',
'city' => 'string',
'Sponsors__sort' => 'integer',
'Sponsors.sort' => 'integer',
'sort' => 'integer'
],
'decorators' => (int) 0,
'executed' => false,
'hydrate' => true,
'buffered' => true,
'formatters' => (int) 0,
'mapReducers' => (int) 0,
'contain' => [],
'matching' => [],
'extraOptions' => [],
'repository' => object(Cake\ORM\Table) {}
}
$ticket_link = ''
$banners = object(Cake\ORM\Query) {
'(help)' => 'This is a Query object, to get the results execute or iterate it.',
'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)',
'params' => [
':c0' => [
[maximum depth reached]
],
':c1' => [
[maximum depth reached]
]
],
'defaultTypes' => [
'Sponsors__id' => 'integer',
'Sponsors.id' => 'integer',
'id' => 'integer',
'Sponsors__link_url' => 'string',
'Sponsors.link_url' => 'string',
'link_url' => 'string',
'Sponsors__image' => 'binary',
'Sponsors.image' => 'binary',
'image' => 'binary',
'Sponsors__hidden' => 'boolean',
'Sponsors.hidden' => 'boolean',
'hidden' => 'boolean',
'Sponsors__category' => 'string',
'Sponsors.category' => 'string',
'category' => 'string',
'Sponsors__description' => 'text',
'Sponsors.description' => 'text',
'description' => 'text',
'Sponsors__city' => 'string',
'Sponsors.city' => 'string',
'city' => 'string',
'Sponsors__sort' => 'integer',
'Sponsors.sort' => 'integer',
'sort' => 'integer'
],
'decorators' => (int) 0,
'executed' => false,
'hydrate' => true,
'buffered' => true,
'formatters' => (int) 0,
'mapReducers' => (int) 0,
'contain' => [],
'matching' => [],
'extraOptions' => [],
'repository' => object(Cake\ORM\Table) {}
}
$festival = 'mia'
$title_slug = 'song lang'
$image = object(Cake\ORM\Entity) {
'id' => (int) 1552,
'parent_table' => 'Films',
'parent_id' => (int) 1245,
'image_group' => 'film_header_images',
'alt_text' => null,
'image_data' => resource,
'sort' => (int) 3,
'[new]' => false,
'[accessible]' => [
'*' => true
],
'[dirty]' => [],
'[original]' => [],
'[virtual]' => [],
'[hasErrors]' => false,
'[errors]' => [],
'[invalid]' => [],
'[repository]' => 'FilmHeaderImages'
}
$key = (int) 3
$festival_pick = object(Cake\ORM\Entity) {
'id' => (int) 401,
'film_id' => (int) 1245,
'festival_pick_user_id' => (int) 99,
'quote' => '"Where art, loss, and regret intersect, an unlikely, heartwarming, and violent love story unfolds."',
'festival_pick_user' => null,
'[new]' => false,
'[accessible]' => [
'*' => true
],
'[dirty]' => [],
'[original]' => [],
'[virtual]' => [],
'[hasErrors]' => false,
'[errors]' => [],
'[invalid]' => [],
'[repository]' => 'FestivalPicks'
}include - ROOT/templates/Films/info.php, line 153 Cake\View\View::_evaluate() - CORE/src/View/View.php, line 1160 Cake\View\View::_render() - CORE/src/View/View.php, line 1121 Cake\View\View::render() - CORE/src/View/View.php, line 751 Cake\Controller\Controller::render() - CORE/src/Controller/Controller.php, line 688 Cake\Controller\Controller::invokeAction() - CORE/src/Controller/Controller.php, line 530 Cake\Controller\ControllerFactory::invoke() - CORE/src/Controller/ControllerFactory.php, line 79 Cake\Http\BaseApplication::handle() - CORE/src/Http/BaseApplication.php, line 229 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 77 Cake\Http\Middleware\BodyParserMiddleware::process() - CORE/src/Http/Middleware/BodyParserMiddleware.php, line 159 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Routing\Middleware\RoutingMiddleware::process() - CORE/src/Routing/Middleware/RoutingMiddleware.php, line 160 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Routing\Middleware\AssetMiddleware::process() - CORE/src/Routing/Middleware/AssetMiddleware.php, line 68 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Error\Middleware\ErrorHandlerMiddleware::process() - CORE/src/Error/Middleware/ErrorHandlerMiddleware.php, line 119 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73
Notice (8): Trying to get property 'name' of non-object [ROOT/templates/Films/info.php, line 153]" />Code Context<div class="festival-pick"><img src="/images/FestivalPickUsers/image/<?= $festival_pick->festival_pick_user->id?>" alt="<?= $festival_pick->festival_pick_user->name; ?>" />$templateFile = '/home/mifo/public_html/templates/Films/info.php' $dataForView = [ 'film' => object(Cake\ORM\Entity) { 'id' => (int) 1245, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'Song Lang', 'genre' => 'Crime, Drama, Gay, Romance, Suspense', 'category' => '', 'streaming_category' => null, 'venue' => 'The Classic Gateway Theatre', 'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304', 'ticket_link' => 'https://tickets.completeticketsolutions.com/OSFF/Online/seatSelect.asp?BOset::WSmap::seatmap::performance_ids=3EB8C6DC-4541-47D2-A6F7-92539ABA69B5', 'virtual_ticket_link' => null, 'party_ticket_link' => null, 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => false, 'streaming_start' => null, 'streaming_end' => null, 'event_id' => null, 'director' => 'Leon Le', 'runtime' => '90 mins', 'language' => 'Vietnamese w/ English Subtitles', 'country' => 'Vietnam', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/lmL5jupLHEs" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'An unlikely bond develops between hunky, brooding and tough debt collector Dung and Linh Phung, a charismatic young opera singer from a struggling Cai-luong troupe (traditional Vietnamese opera). The two meet when Dung comes to forcefully collect a debt from the opera troupe, but when their paths cross again, a friendship - and then more - develops, awakening surprising, tender feelings in both men. Their story, too, soon scales operatic heights. Director Leon Le has delivered a rich drama, a smoldering relationship between two apparent opposites set against the backdrop of a gorgeous, fading art form. Set in 1980's Saigon, <i>Song Lang</i> is a gritty underworld noir hiding a tender, romantic heart.', 'logline' => null, 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => null, 'community_partner_link' => '', 'community_partner_enabled' => false, 'community_partner2' => null, 'community_partner_link2' => '', 'community_partner_enabled2' => false, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Festival', 'event' => null, 'film_header_images' => [ [maximum depth reached] ], 'festival_pick_talent' => [[maximum depth reached]], 'festival_picks' => [ [maximum depth reached] ], '[new]' => false, '[accessible]' => [ [maximum depth reached] ], '[dirty]' => [[maximum depth reached]], '[original]' => [[maximum depth reached]], '[virtual]' => [[maximum depth reached]], '[hasErrors]' => false, '[errors]' => [[maximum depth reached]], '[invalid]' => [[maximum depth reached]], '[repository]' => 'Films' }, 'suggested_films' => [ (int) 0 => object(Cake\ORM\Entity) {}, (int) 1 => object(Cake\ORM\Entity) {} ], 'title' => 'OUTshine Film Festival - Song Lang', 'presenting_sponsors' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'sponsors_loop' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'skyscrapers' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'ticket_link' => '', 'banners' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'festival' => 'mia' ] $film = object(Cake\ORM\Entity) { 'id' => (int) 1245, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'Song Lang', 'genre' => 'Crime, Drama, Gay, Romance, Suspense', 'category' => '', 'streaming_category' => null, 'venue' => 'The Classic Gateway Theatre', 'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304', 'ticket_link' => 'https://tickets.completeticketsolutions.com/OSFF/Online/seatSelect.asp?BOset::WSmap::seatmap::performance_ids=3EB8C6DC-4541-47D2-A6F7-92539ABA69B5', 'virtual_ticket_link' => null, 'party_ticket_link' => null, 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => false, 'streaming_start' => null, 'streaming_end' => null, 'event_id' => null, 'director' => 'Leon Le', 'runtime' => '90 mins', 'language' => 'Vietnamese w/ English Subtitles', 'country' => 'Vietnam', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/lmL5jupLHEs" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'An unlikely bond develops between hunky, brooding and tough debt collector Dung and Linh Phung, a charismatic young opera singer from a struggling Cai-luong troupe (traditional Vietnamese opera). The two meet when Dung comes to forcefully collect a debt from the opera troupe, but when their paths cross again, a friendship - and then more - develops, awakening surprising, tender feelings in both men. Their story, too, soon scales operatic heights. Director Leon Le has delivered a rich drama, a smoldering relationship between two apparent opposites set against the backdrop of a gorgeous, fading art form. Set in 1980's Saigon, <i>Song Lang</i> is a gritty underworld noir hiding a tender, romantic heart.', 'logline' => null, 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => null, 'community_partner_link' => '', 'community_partner_enabled' => false, 'community_partner2' => null, 'community_partner_link2' => '', 'community_partner_enabled2' => false, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Festival', 'event' => null, 'film_header_images' => [ (int) 0 => object(Cake\ORM\Entity) {}, (int) 1 => object(Cake\ORM\Entity) {}, (int) 2 => object(Cake\ORM\Entity) {}, (int) 3 => object(Cake\ORM\Entity) {} ], 'festival_pick_talent' => [], 'festival_picks' => [ (int) 0 => object(Cake\ORM\Entity) {}, (int) 1 => object(Cake\ORM\Entity) {} ], '[new]' => false, '[accessible]' => [ '*' => true ], '[dirty]' => [], '[original]' => [], '[virtual]' => [], '[hasErrors]' => false, '[errors]' => [], '[invalid]' => [], '[repository]' => 'Films' } $suggested_films = [ (int) 0 => object(Cake\ORM\Entity) { 'id' => (int) 2002, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'The Divine Tragedy (La Divina Tragedia)', 'genre' => 'Comedy, Drama, Gay', 'category' => '', 'streaming_category' => '', 'venue' => 'Paradigm Cinemas: Gateway Fort Lauderdale', 'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304', 'ticket_link' => 'https://outshinespring2026.eventive.org/schedule/69c6cb71fe9976d6a967cc2a', 'virtual_ticket_link' => 'https://watch.eventive.org/outshinespring2026/play/69c6da7f654a19ba46364dc8', 'party_ticket_link' => '', 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => true, 'streaming_start' => object(Cake\I18n\FrozenTime) {}, 'streaming_end' => object(Cake\I18n\FrozenTime) {}, 'event_id' => null, 'director' => 'Sergio Tovar Velarde', 'runtime' => '102 Minutes', 'language' => 'Spanish', 'country' => 'Mexico, 2025', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/YSmjk11Ft8E?si=JDS_MdLknzEbUatB" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'After 25 years together, Cristian’s life is upended when his long-term relationship ends abruptly. Forced to abandon his life of luxury, he moves in with his half-brother Roy, a much younger, openly gay man whose chaotic lifestyle clashes with Cristian’s need for order. As the two opposites navigate cramped quarters, old wounds, and new beginnings, they must learn to coexist—and maybe even support each other—in ways neither expected. The Divine Tragedy is a sharply funny, yet tender dramedy about midlife reinvention, unexpected brotherhood, and the messy, beautiful process of starting over when everything you knew falls apart.', 'logline' => 'When Cristian’s decades-long relationship ends, he’s forced to move in with his chaotic, younger gay half-brother, Roy. As opposites collide under one roof, both men must confront past regrets and unexpected bonds in a search for renewal.', 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => resource, 'community_partner_link' => 'https://preventionx.org/', 'community_partner_enabled' => true, 'community_partner2' => null, 'community_partner_link2' => '', 'community_partner_enabled2' => false, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Spring Edition', 'film_header_images' => [ [maximum depth reached] ], '[new]' => false, '[accessible]' => [ [maximum depth reached] ], '[dirty]' => [[maximum depth reached]], '[original]' => [[maximum depth reached]], '[virtual]' => [[maximum depth reached]], '[hasErrors]' => false, '[errors]' => [[maximum depth reached]], '[invalid]' => [[maximum depth reached]], '[repository]' => 'Films' }, (int) 1 => object(Cake\ORM\Entity) { 'id' => (int) 1977, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'CLOSING NIGHT FILM & PARTY: We’ll Find Happiness (On Sera Heureux)', 'genre' => 'Drama, Gay, Romance', 'category' => '', 'streaming_category' => '', 'venue' => 'Savor Cinema', 'venue_address' => '503 SE 6th St, Fort Lauderdale, FL 33301', 'ticket_link' => '', 'virtual_ticket_link' => '', 'party_ticket_link' => 'https://outshinespring2026.eventive.org/schedule/69c6cf7b8a7ebad6fa7ae8d2', 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => false, 'streaming_start' => object(Cake\I18n\FrozenTime) {}, 'streaming_end' => object(Cake\I18n\FrozenTime) {}, 'event_id' => null, 'director' => 'Lea Pool', 'runtime' => '102 minutes', 'language' => 'French, English, Farsi, Arabic', 'country' => 'Canada, 2025', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/Nj7DjOGdnIs?si=nfYl7MW3yL-bfpyH" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'Saad, a young Moroccan exile in Quebec with secrets of his own, will do anything to save the man he loves, Reza, an Iranian refugee facing deportation and likely death. In a desperate gamble, Saad attempts to seduce Laurent, a gorgeous, high-ranking Ministry of Immigration spokesperson, triggering a chain of events that are as intimate as they are political. Traversing Iran, Spain, France, and Canada in a stylish fury, We’ll Find Happiness crafts a rare, powerful, and timely portrait of LGBTQ+ refugees, blending passion, sacrifice, and the relentless pursuit of freedom.', 'logline' => 'A Moroccan exile risks everything to save his deportation-threatened lover, sparking a tense and deeply personal struggle that intertwines love, politics, and the fight for freedom.', 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => resource, 'community_partner_link' => 'http://eqfl.org', 'community_partner_enabled' => true, 'community_partner2' => resource, 'community_partner_link2' => 'https://www.latinossalud.org/', 'community_partner_enabled2' => true, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Spring Edition', 'film_header_images' => [ [maximum depth reached] ], '[new]' => false, '[accessible]' => [ [maximum depth reached] ], '[dirty]' => [[maximum depth reached]], '[original]' => [[maximum depth reached]], '[virtual]' => [[maximum depth reached]], '[hasErrors]' => false, '[errors]' => [[maximum depth reached]], '[invalid]' => [[maximum depth reached]], '[repository]' => 'Films' } ] $title = 'OUTshine Film Festival - Song Lang' $presenting_sponsors = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $sponsors_loop = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $skyscrapers = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $ticket_link = '' $banners = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $festival = 'mia' $title_slug = 'song lang' $image = object(Cake\ORM\Entity) { 'id' => (int) 1552, 'parent_table' => 'Films', 'parent_id' => (int) 1245, 'image_group' => 'film_header_images', 'alt_text' => null, 'image_data' => resource, 'sort' => (int) 3, '[new]' => false, '[accessible]' => [ '*' => true ], '[dirty]' => [], '[original]' => [], '[virtual]' => [], '[hasErrors]' => false, '[errors]' => [], '[invalid]' => [], '[repository]' => 'FilmHeaderImages' } $key = (int) 3 $festival_pick = object(Cake\ORM\Entity) { 'id' => (int) 401, 'film_id' => (int) 1245, 'festival_pick_user_id' => (int) 99, 'quote' => '"Where art, loss, and regret intersect, an unlikely, heartwarming, and violent love story unfolds."', 'festival_pick_user' => null, '[new]' => false, '[accessible]' => [ '*' => true ], '[dirty]' => [], '[original]' => [], '[virtual]' => [], '[hasErrors]' => false, '[errors]' => [], '[invalid]' => [], '[repository]' => 'FestivalPicks' }include - ROOT/templates/Films/info.php, line 153 Cake\View\View::_evaluate() - CORE/src/View/View.php, line 1160 Cake\View\View::_render() - CORE/src/View/View.php, line 1121 Cake\View\View::render() - CORE/src/View/View.php, line 751 Cake\Controller\Controller::render() - CORE/src/Controller/Controller.php, line 688 Cake\Controller\Controller::invokeAction() - CORE/src/Controller/Controller.php, line 530 Cake\Controller\ControllerFactory::invoke() - CORE/src/Controller/ControllerFactory.php, line 79 Cake\Http\BaseApplication::handle() - CORE/src/Http/BaseApplication.php, line 229 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 77 Cake\Http\Middleware\BodyParserMiddleware::process() - CORE/src/Http/Middleware/BodyParserMiddleware.php, line 159 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Routing\Middleware\RoutingMiddleware::process() - CORE/src/Routing/Middleware/RoutingMiddleware.php, line 160 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Routing\Middleware\AssetMiddleware::process() - CORE/src/Routing/Middleware/AssetMiddleware.php, line 68 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Error\Middleware\ErrorHandlerMiddleware::process() - CORE/src/Error/Middleware/ErrorHandlerMiddleware.php, line 119 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73
Notice (8): Trying to get property 'name' of non-object [ROOT/templates/Films/info.php, line 156]-Code Context<div class="festival-pick-info"><p class="festival-picks-name"><?= $festival_pick->festival_pick_user->name; ?> - <?= $festival_pick->festival_pick_user->title; ?></p><?php if(!empty($festival_pick->quote)): ?>$templateFile = '/home/mifo/public_html/templates/Films/info.php' $dataForView = [ 'film' => object(Cake\ORM\Entity) { 'id' => (int) 1245, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'Song Lang', 'genre' => 'Crime, Drama, Gay, Romance, Suspense', 'category' => '', 'streaming_category' => null, 'venue' => 'The Classic Gateway Theatre', 'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304', 'ticket_link' => 'https://tickets.completeticketsolutions.com/OSFF/Online/seatSelect.asp?BOset::WSmap::seatmap::performance_ids=3EB8C6DC-4541-47D2-A6F7-92539ABA69B5', 'virtual_ticket_link' => null, 'party_ticket_link' => null, 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => false, 'streaming_start' => null, 'streaming_end' => null, 'event_id' => null, 'director' => 'Leon Le', 'runtime' => '90 mins', 'language' => 'Vietnamese w/ English Subtitles', 'country' => 'Vietnam', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/lmL5jupLHEs" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'An unlikely bond develops between hunky, brooding and tough debt collector Dung and Linh Phung, a charismatic young opera singer from a struggling Cai-luong troupe (traditional Vietnamese opera). The two meet when Dung comes to forcefully collect a debt from the opera troupe, but when their paths cross again, a friendship - and then more - develops, awakening surprising, tender feelings in both men. Their story, too, soon scales operatic heights. Director Leon Le has delivered a rich drama, a smoldering relationship between two apparent opposites set against the backdrop of a gorgeous, fading art form. Set in 1980's Saigon, <i>Song Lang</i> is a gritty underworld noir hiding a tender, romantic heart.', 'logline' => null, 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => null, 'community_partner_link' => '', 'community_partner_enabled' => false, 'community_partner2' => null, 'community_partner_link2' => '', 'community_partner_enabled2' => false, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Festival', 'event' => null, 'film_header_images' => [ [maximum depth reached] ], 'festival_pick_talent' => [[maximum depth reached]], 'festival_picks' => [ [maximum depth reached] ], '[new]' => false, '[accessible]' => [ [maximum depth reached] ], '[dirty]' => [[maximum depth reached]], '[original]' => [[maximum depth reached]], '[virtual]' => [[maximum depth reached]], '[hasErrors]' => false, '[errors]' => [[maximum depth reached]], '[invalid]' => [[maximum depth reached]], '[repository]' => 'Films' }, 'suggested_films' => [ (int) 0 => object(Cake\ORM\Entity) {}, (int) 1 => object(Cake\ORM\Entity) {} ], 'title' => 'OUTshine Film Festival - Song Lang', 'presenting_sponsors' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'sponsors_loop' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'skyscrapers' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'ticket_link' => '', 'banners' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'festival' => 'mia' ] $film = object(Cake\ORM\Entity) { 'id' => (int) 1245, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'Song Lang', 'genre' => 'Crime, Drama, Gay, Romance, Suspense', 'category' => '', 'streaming_category' => null, 'venue' => 'The Classic Gateway Theatre', 'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304', 'ticket_link' => 'https://tickets.completeticketsolutions.com/OSFF/Online/seatSelect.asp?BOset::WSmap::seatmap::performance_ids=3EB8C6DC-4541-47D2-A6F7-92539ABA69B5', 'virtual_ticket_link' => null, 'party_ticket_link' => null, 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => false, 'streaming_start' => null, 'streaming_end' => null, 'event_id' => null, 'director' => 'Leon Le', 'runtime' => '90 mins', 'language' => 'Vietnamese w/ English Subtitles', 'country' => 'Vietnam', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/lmL5jupLHEs" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'An unlikely bond develops between hunky, brooding and tough debt collector Dung and Linh Phung, a charismatic young opera singer from a struggling Cai-luong troupe (traditional Vietnamese opera). The two meet when Dung comes to forcefully collect a debt from the opera troupe, but when their paths cross again, a friendship - and then more - develops, awakening surprising, tender feelings in both men. Their story, too, soon scales operatic heights. Director Leon Le has delivered a rich drama, a smoldering relationship between two apparent opposites set against the backdrop of a gorgeous, fading art form. Set in 1980's Saigon, <i>Song Lang</i> is a gritty underworld noir hiding a tender, romantic heart.', 'logline' => null, 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => null, 'community_partner_link' => '', 'community_partner_enabled' => false, 'community_partner2' => null, 'community_partner_link2' => '', 'community_partner_enabled2' => false, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Festival', 'event' => null, 'film_header_images' => [ (int) 0 => object(Cake\ORM\Entity) {}, (int) 1 => object(Cake\ORM\Entity) {}, (int) 2 => object(Cake\ORM\Entity) {}, (int) 3 => object(Cake\ORM\Entity) {} ], 'festival_pick_talent' => [], 'festival_picks' => [ (int) 0 => object(Cake\ORM\Entity) {}, (int) 1 => object(Cake\ORM\Entity) {} ], '[new]' => false, '[accessible]' => [ '*' => true ], '[dirty]' => [], '[original]' => [], '[virtual]' => [], '[hasErrors]' => false, '[errors]' => [], '[invalid]' => [], '[repository]' => 'Films' } $suggested_films = [ (int) 0 => object(Cake\ORM\Entity) { 'id' => (int) 2002, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'The Divine Tragedy (La Divina Tragedia)', 'genre' => 'Comedy, Drama, Gay', 'category' => '', 'streaming_category' => '', 'venue' => 'Paradigm Cinemas: Gateway Fort Lauderdale', 'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304', 'ticket_link' => 'https://outshinespring2026.eventive.org/schedule/69c6cb71fe9976d6a967cc2a', 'virtual_ticket_link' => 'https://watch.eventive.org/outshinespring2026/play/69c6da7f654a19ba46364dc8', 'party_ticket_link' => '', 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => true, 'streaming_start' => object(Cake\I18n\FrozenTime) {}, 'streaming_end' => object(Cake\I18n\FrozenTime) {}, 'event_id' => null, 'director' => 'Sergio Tovar Velarde', 'runtime' => '102 Minutes', 'language' => 'Spanish', 'country' => 'Mexico, 2025', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/YSmjk11Ft8E?si=JDS_MdLknzEbUatB" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'After 25 years together, Cristian’s life is upended when his long-term relationship ends abruptly. Forced to abandon his life of luxury, he moves in with his half-brother Roy, a much younger, openly gay man whose chaotic lifestyle clashes with Cristian’s need for order. As the two opposites navigate cramped quarters, old wounds, and new beginnings, they must learn to coexist—and maybe even support each other—in ways neither expected. The Divine Tragedy is a sharply funny, yet tender dramedy about midlife reinvention, unexpected brotherhood, and the messy, beautiful process of starting over when everything you knew falls apart.', 'logline' => 'When Cristian’s decades-long relationship ends, he’s forced to move in with his chaotic, younger gay half-brother, Roy. As opposites collide under one roof, both men must confront past regrets and unexpected bonds in a search for renewal.', 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => resource, 'community_partner_link' => 'https://preventionx.org/', 'community_partner_enabled' => true, 'community_partner2' => null, 'community_partner_link2' => '', 'community_partner_enabled2' => false, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Spring Edition', 'film_header_images' => [ [maximum depth reached] ], '[new]' => false, '[accessible]' => [ [maximum depth reached] ], '[dirty]' => [[maximum depth reached]], '[original]' => [[maximum depth reached]], '[virtual]' => [[maximum depth reached]], '[hasErrors]' => false, '[errors]' => [[maximum depth reached]], '[invalid]' => [[maximum depth reached]], '[repository]' => 'Films' }, (int) 1 => object(Cake\ORM\Entity) { 'id' => (int) 1977, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'CLOSING NIGHT FILM & PARTY: We’ll Find Happiness (On Sera Heureux)', 'genre' => 'Drama, Gay, Romance', 'category' => '', 'streaming_category' => '', 'venue' => 'Savor Cinema', 'venue_address' => '503 SE 6th St, Fort Lauderdale, FL 33301', 'ticket_link' => '', 'virtual_ticket_link' => '', 'party_ticket_link' => 'https://outshinespring2026.eventive.org/schedule/69c6cf7b8a7ebad6fa7ae8d2', 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => false, 'streaming_start' => object(Cake\I18n\FrozenTime) {}, 'streaming_end' => object(Cake\I18n\FrozenTime) {}, 'event_id' => null, 'director' => 'Lea Pool', 'runtime' => '102 minutes', 'language' => 'French, English, Farsi, Arabic', 'country' => 'Canada, 2025', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/Nj7DjOGdnIs?si=nfYl7MW3yL-bfpyH" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'Saad, a young Moroccan exile in Quebec with secrets of his own, will do anything to save the man he loves, Reza, an Iranian refugee facing deportation and likely death. In a desperate gamble, Saad attempts to seduce Laurent, a gorgeous, high-ranking Ministry of Immigration spokesperson, triggering a chain of events that are as intimate as they are political. Traversing Iran, Spain, France, and Canada in a stylish fury, We’ll Find Happiness crafts a rare, powerful, and timely portrait of LGBTQ+ refugees, blending passion, sacrifice, and the relentless pursuit of freedom.', 'logline' => 'A Moroccan exile risks everything to save his deportation-threatened lover, sparking a tense and deeply personal struggle that intertwines love, politics, and the fight for freedom.', 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => resource, 'community_partner_link' => 'http://eqfl.org', 'community_partner_enabled' => true, 'community_partner2' => resource, 'community_partner_link2' => 'https://www.latinossalud.org/', 'community_partner_enabled2' => true, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Spring Edition', 'film_header_images' => [ [maximum depth reached] ], '[new]' => false, '[accessible]' => [ [maximum depth reached] ], '[dirty]' => [[maximum depth reached]], '[original]' => [[maximum depth reached]], '[virtual]' => [[maximum depth reached]], '[hasErrors]' => false, '[errors]' => [[maximum depth reached]], '[invalid]' => [[maximum depth reached]], '[repository]' => 'Films' } ] $title = 'OUTshine Film Festival - Song Lang' $presenting_sponsors = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $sponsors_loop = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $skyscrapers = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $ticket_link = '' $banners = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $festival = 'mia' $title_slug = 'song lang' $image = object(Cake\ORM\Entity) { 'id' => (int) 1552, 'parent_table' => 'Films', 'parent_id' => (int) 1245, 'image_group' => 'film_header_images', 'alt_text' => null, 'image_data' => resource, 'sort' => (int) 3, '[new]' => false, '[accessible]' => [ '*' => true ], '[dirty]' => [], '[original]' => [], '[virtual]' => [], '[hasErrors]' => false, '[errors]' => [], '[invalid]' => [], '[repository]' => 'FilmHeaderImages' } $key = (int) 3 $festival_pick = object(Cake\ORM\Entity) { 'id' => (int) 401, 'film_id' => (int) 1245, 'festival_pick_user_id' => (int) 99, 'quote' => '"Where art, loss, and regret intersect, an unlikely, heartwarming, and violent love story unfolds."', 'festival_pick_user' => null, '[new]' => false, '[accessible]' => [ '*' => true ], '[dirty]' => [], '[original]' => [], '[virtual]' => [], '[hasErrors]' => false, '[errors]' => [], '[invalid]' => [], '[repository]' => 'FestivalPicks' }include - ROOT/templates/Films/info.php, line 156 Cake\View\View::_evaluate() - CORE/src/View/View.php, line 1160 Cake\View\View::_render() - CORE/src/View/View.php, line 1121 Cake\View\View::render() - CORE/src/View/View.php, line 751 Cake\Controller\Controller::render() - CORE/src/Controller/Controller.php, line 688 Cake\Controller\Controller::invokeAction() - CORE/src/Controller/Controller.php, line 530 Cake\Controller\ControllerFactory::invoke() - CORE/src/Controller/ControllerFactory.php, line 79 Cake\Http\BaseApplication::handle() - CORE/src/Http/BaseApplication.php, line 229 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 77 Cake\Http\Middleware\BodyParserMiddleware::process() - CORE/src/Http/Middleware/BodyParserMiddleware.php, line 159 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Routing\Middleware\RoutingMiddleware::process() - CORE/src/Routing/Middleware/RoutingMiddleware.php, line 160 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Routing\Middleware\AssetMiddleware::process() - CORE/src/Routing/Middleware/AssetMiddleware.php, line 68 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Error\Middleware\ErrorHandlerMiddleware::process() - CORE/src/Error/Middleware/ErrorHandlerMiddleware.php, line 119 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73
Notice (8): Trying to get property 'title' of non-object [ROOT/templates/Films/info.php, line 156]Code Context<div class="festival-pick-info"><p class="festival-picks-name"><?= $festival_pick->festival_pick_user->name; ?> - <?= $festival_pick->festival_pick_user->title; ?></p><?php if(!empty($festival_pick->quote)): ?>$templateFile = '/home/mifo/public_html/templates/Films/info.php' $dataForView = [ 'film' => object(Cake\ORM\Entity) { 'id' => (int) 1245, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'Song Lang', 'genre' => 'Crime, Drama, Gay, Romance, Suspense', 'category' => '', 'streaming_category' => null, 'venue' => 'The Classic Gateway Theatre', 'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304', 'ticket_link' => 'https://tickets.completeticketsolutions.com/OSFF/Online/seatSelect.asp?BOset::WSmap::seatmap::performance_ids=3EB8C6DC-4541-47D2-A6F7-92539ABA69B5', 'virtual_ticket_link' => null, 'party_ticket_link' => null, 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => false, 'streaming_start' => null, 'streaming_end' => null, 'event_id' => null, 'director' => 'Leon Le', 'runtime' => '90 mins', 'language' => 'Vietnamese w/ English Subtitles', 'country' => 'Vietnam', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/lmL5jupLHEs" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'An unlikely bond develops between hunky, brooding and tough debt collector Dung and Linh Phung, a charismatic young opera singer from a struggling Cai-luong troupe (traditional Vietnamese opera). The two meet when Dung comes to forcefully collect a debt from the opera troupe, but when their paths cross again, a friendship - and then more - develops, awakening surprising, tender feelings in both men. Their story, too, soon scales operatic heights. Director Leon Le has delivered a rich drama, a smoldering relationship between two apparent opposites set against the backdrop of a gorgeous, fading art form. Set in 1980's Saigon, <i>Song Lang</i> is a gritty underworld noir hiding a tender, romantic heart.', 'logline' => null, 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => null, 'community_partner_link' => '', 'community_partner_enabled' => false, 'community_partner2' => null, 'community_partner_link2' => '', 'community_partner_enabled2' => false, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Festival', 'event' => null, 'film_header_images' => [ [maximum depth reached] ], 'festival_pick_talent' => [[maximum depth reached]], 'festival_picks' => [ [maximum depth reached] ], '[new]' => false, '[accessible]' => [ [maximum depth reached] ], '[dirty]' => [[maximum depth reached]], '[original]' => [[maximum depth reached]], '[virtual]' => [[maximum depth reached]], '[hasErrors]' => false, '[errors]' => [[maximum depth reached]], '[invalid]' => [[maximum depth reached]], '[repository]' => 'Films' }, 'suggested_films' => [ (int) 0 => object(Cake\ORM\Entity) {}, (int) 1 => object(Cake\ORM\Entity) {} ], 'title' => 'OUTshine Film Festival - Song Lang', 'presenting_sponsors' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'sponsors_loop' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'skyscrapers' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'ticket_link' => '', 'banners' => object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ [maximum depth reached] ], 'defaultTypes' => [ [maximum depth reached] ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [[maximum depth reached]], 'matching' => [[maximum depth reached]], 'extraOptions' => [[maximum depth reached]], 'repository' => object(Cake\ORM\Table) {} }, 'festival' => 'mia' ] $film = object(Cake\ORM\Entity) { 'id' => (int) 1245, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'Song Lang', 'genre' => 'Crime, Drama, Gay, Romance, Suspense', 'category' => '', 'streaming_category' => null, 'venue' => 'The Classic Gateway Theatre', 'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304', 'ticket_link' => 'https://tickets.completeticketsolutions.com/OSFF/Online/seatSelect.asp?BOset::WSmap::seatmap::performance_ids=3EB8C6DC-4541-47D2-A6F7-92539ABA69B5', 'virtual_ticket_link' => null, 'party_ticket_link' => null, 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => false, 'streaming_start' => null, 'streaming_end' => null, 'event_id' => null, 'director' => 'Leon Le', 'runtime' => '90 mins', 'language' => 'Vietnamese w/ English Subtitles', 'country' => 'Vietnam', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/lmL5jupLHEs" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'An unlikely bond develops between hunky, brooding and tough debt collector Dung and Linh Phung, a charismatic young opera singer from a struggling Cai-luong troupe (traditional Vietnamese opera). The two meet when Dung comes to forcefully collect a debt from the opera troupe, but when their paths cross again, a friendship - and then more - develops, awakening surprising, tender feelings in both men. Their story, too, soon scales operatic heights. Director Leon Le has delivered a rich drama, a smoldering relationship between two apparent opposites set against the backdrop of a gorgeous, fading art form. Set in 1980's Saigon, <i>Song Lang</i> is a gritty underworld noir hiding a tender, romantic heart.', 'logline' => null, 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => null, 'community_partner_link' => '', 'community_partner_enabled' => false, 'community_partner2' => null, 'community_partner_link2' => '', 'community_partner_enabled2' => false, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Festival', 'event' => null, 'film_header_images' => [ (int) 0 => object(Cake\ORM\Entity) {}, (int) 1 => object(Cake\ORM\Entity) {}, (int) 2 => object(Cake\ORM\Entity) {}, (int) 3 => object(Cake\ORM\Entity) {} ], 'festival_pick_talent' => [], 'festival_picks' => [ (int) 0 => object(Cake\ORM\Entity) {}, (int) 1 => object(Cake\ORM\Entity) {} ], '[new]' => false, '[accessible]' => [ '*' => true ], '[dirty]' => [], '[original]' => [], '[virtual]' => [], '[hasErrors]' => false, '[errors]' => [], '[invalid]' => [], '[repository]' => 'Films' } $suggested_films = [ (int) 0 => object(Cake\ORM\Entity) { 'id' => (int) 2002, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'The Divine Tragedy (La Divina Tragedia)', 'genre' => 'Comedy, Drama, Gay', 'category' => '', 'streaming_category' => '', 'venue' => 'Paradigm Cinemas: Gateway Fort Lauderdale', 'venue_address' => '1820 E Sunrise Blvd, Fort Lauderdale, FL 33304', 'ticket_link' => 'https://outshinespring2026.eventive.org/schedule/69c6cb71fe9976d6a967cc2a', 'virtual_ticket_link' => 'https://watch.eventive.org/outshinespring2026/play/69c6da7f654a19ba46364dc8', 'party_ticket_link' => '', 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => true, 'streaming_start' => object(Cake\I18n\FrozenTime) {}, 'streaming_end' => object(Cake\I18n\FrozenTime) {}, 'event_id' => null, 'director' => 'Sergio Tovar Velarde', 'runtime' => '102 Minutes', 'language' => 'Spanish', 'country' => 'Mexico, 2025', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/YSmjk11Ft8E?si=JDS_MdLknzEbUatB" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'After 25 years together, Cristian’s life is upended when his long-term relationship ends abruptly. Forced to abandon his life of luxury, he moves in with his half-brother Roy, a much younger, openly gay man whose chaotic lifestyle clashes with Cristian’s need for order. As the two opposites navigate cramped quarters, old wounds, and new beginnings, they must learn to coexist—and maybe even support each other—in ways neither expected. The Divine Tragedy is a sharply funny, yet tender dramedy about midlife reinvention, unexpected brotherhood, and the messy, beautiful process of starting over when everything you knew falls apart.', 'logline' => 'When Cristian’s decades-long relationship ends, he’s forced to move in with his chaotic, younger gay half-brother, Roy. As opposites collide under one roof, both men must confront past regrets and unexpected bonds in a search for renewal.', 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => resource, 'community_partner_link' => 'https://preventionx.org/', 'community_partner_enabled' => true, 'community_partner2' => null, 'community_partner_link2' => '', 'community_partner_enabled2' => false, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Spring Edition', 'film_header_images' => [ [maximum depth reached] ], '[new]' => false, '[accessible]' => [ [maximum depth reached] ], '[dirty]' => [[maximum depth reached]], '[original]' => [[maximum depth reached]], '[virtual]' => [[maximum depth reached]], '[hasErrors]' => false, '[errors]' => [[maximum depth reached]], '[invalid]' => [[maximum depth reached]], '[repository]' => 'Films' }, (int) 1 => object(Cake\ORM\Entity) { 'id' => (int) 1977, 'poster' => null, 'visible' => true, 'spotlight' => false, 'title' => 'CLOSING NIGHT FILM & PARTY: We’ll Find Happiness (On Sera Heureux)', 'genre' => 'Drama, Gay, Romance', 'category' => '', 'streaming_category' => '', 'venue' => 'Savor Cinema', 'venue_address' => '503 SE 6th St, Fort Lauderdale, FL 33301', 'ticket_link' => '', 'virtual_ticket_link' => '', 'party_ticket_link' => 'https://outshinespring2026.eventive.org/schedule/69c6cf7b8a7ebad6fa7ae8d2', 'in_theaters' => true, 'datetime' => object(Cake\I18n\FrozenTime) {}, 'has_endtime' => false, 'endtime' => null, 'is_streaming' => false, 'streaming_start' => object(Cake\I18n\FrozenTime) {}, 'streaming_end' => object(Cake\I18n\FrozenTime) {}, 'event_id' => null, 'director' => 'Lea Pool', 'runtime' => '102 minutes', 'language' => 'French, English, Farsi, Arabic', 'country' => 'Canada, 2025', 'youtube_link' => '<iframe width="560" height="315" src="https://www.youtube.com/embed/Nj7DjOGdnIs?si=nfYl7MW3yL-bfpyH" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe>', 'twitter_link' => null, 'facebook_link' => '', 'synopsis' => 'Saad, a young Moroccan exile in Quebec with secrets of his own, will do anything to save the man he loves, Reza, an Iranian refugee facing deportation and likely death. In a desperate gamble, Saad attempts to seduce Laurent, a gorgeous, high-ranking Ministry of Immigration spokesperson, triggering a chain of events that are as intimate as they are political. Traversing Iran, Spain, France, and Canada in a stylish fury, We’ll Find Happiness crafts a rare, powerful, and timely portrait of LGBTQ+ refugees, blending passion, sacrifice, and the relentless pursuit of freedom.', 'logline' => 'A Moroccan exile risks everything to save his deportation-threatened lover, sparking a tense and deeply personal struggle that intertwines love, politics, and the fight for freedom.', 'image' => null, 'thumbnail' => null, 'additional_info' => '', 'preceded_by' => '', 'community_partner' => resource, 'community_partner_link' => 'http://eqfl.org', 'community_partner_enabled' => true, 'community_partner2' => resource, 'community_partner_link2' => 'https://www.latinossalud.org/', 'community_partner_enabled2' => true, 'sponsor' => null, 'sponsor_link' => '', 'sponsor_enabled' => false, 'year' => null, 'city' => 'ftl', 'series' => 'Spring Edition', 'film_header_images' => [ [maximum depth reached] ], '[new]' => false, '[accessible]' => [ [maximum depth reached] ], '[dirty]' => [[maximum depth reached]], '[original]' => [[maximum depth reached]], '[virtual]' => [[maximum depth reached]], '[hasErrors]' => false, '[errors]' => [[maximum depth reached]], '[invalid]' => [[maximum depth reached]], '[repository]' => 'Films' } ] $title = 'OUTshine Film Festival - Song Lang' $presenting_sponsors = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $sponsors_loop = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $skyscrapers = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $ticket_link = '' $banners = object(Cake\ORM\Query) { '(help)' => 'This is a Query object, to get the results execute or iterate it.', 'sql' => 'SELECT Sponsors.id AS Sponsors__id, Sponsors.link_url AS Sponsors__link_url, Sponsors.image AS Sponsors__image, Sponsors.hidden AS Sponsors__hidden, Sponsors.category AS Sponsors__category, Sponsors.description AS Sponsors__description, Sponsors.city AS Sponsors__city, Sponsors.sort AS Sponsors__sort FROM sponsors Sponsors WHERE (hidden = :c0 AND category = :c1)', 'params' => [ ':c0' => [ [maximum depth reached] ], ':c1' => [ [maximum depth reached] ] ], 'defaultTypes' => [ 'Sponsors__id' => 'integer', 'Sponsors.id' => 'integer', 'id' => 'integer', 'Sponsors__link_url' => 'string', 'Sponsors.link_url' => 'string', 'link_url' => 'string', 'Sponsors__image' => 'binary', 'Sponsors.image' => 'binary', 'image' => 'binary', 'Sponsors__hidden' => 'boolean', 'Sponsors.hidden' => 'boolean', 'hidden' => 'boolean', 'Sponsors__category' => 'string', 'Sponsors.category' => 'string', 'category' => 'string', 'Sponsors__description' => 'text', 'Sponsors.description' => 'text', 'description' => 'text', 'Sponsors__city' => 'string', 'Sponsors.city' => 'string', 'city' => 'string', 'Sponsors__sort' => 'integer', 'Sponsors.sort' => 'integer', 'sort' => 'integer' ], 'decorators' => (int) 0, 'executed' => false, 'hydrate' => true, 'buffered' => true, 'formatters' => (int) 0, 'mapReducers' => (int) 0, 'contain' => [], 'matching' => [], 'extraOptions' => [], 'repository' => object(Cake\ORM\Table) {} } $festival = 'mia' $title_slug = 'song lang' $image = object(Cake\ORM\Entity) { 'id' => (int) 1552, 'parent_table' => 'Films', 'parent_id' => (int) 1245, 'image_group' => 'film_header_images', 'alt_text' => null, 'image_data' => resource, 'sort' => (int) 3, '[new]' => false, '[accessible]' => [ '*' => true ], '[dirty]' => [], '[original]' => [], '[virtual]' => [], '[hasErrors]' => false, '[errors]' => [], '[invalid]' => [], '[repository]' => 'FilmHeaderImages' } $key = (int) 3 $festival_pick = object(Cake\ORM\Entity) { 'id' => (int) 401, 'film_id' => (int) 1245, 'festival_pick_user_id' => (int) 99, 'quote' => '"Where art, loss, and regret intersect, an unlikely, heartwarming, and violent love story unfolds."', 'festival_pick_user' => null, '[new]' => false, '[accessible]' => [ '*' => true ], '[dirty]' => [], '[original]' => [], '[virtual]' => [], '[hasErrors]' => false, '[errors]' => [], '[invalid]' => [], '[repository]' => 'FestivalPicks' }include - ROOT/templates/Films/info.php, line 156 Cake\View\View::_evaluate() - CORE/src/View/View.php, line 1160 Cake\View\View::_render() - CORE/src/View/View.php, line 1121 Cake\View\View::render() - CORE/src/View/View.php, line 751 Cake\Controller\Controller::render() - CORE/src/Controller/Controller.php, line 688 Cake\Controller\Controller::invokeAction() - CORE/src/Controller/Controller.php, line 530 Cake\Controller\ControllerFactory::invoke() - CORE/src/Controller/ControllerFactory.php, line 79 Cake\Http\BaseApplication::handle() - CORE/src/Http/BaseApplication.php, line 229 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 77 Cake\Http\Middleware\BodyParserMiddleware::process() - CORE/src/Http/Middleware/BodyParserMiddleware.php, line 159 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Routing\Middleware\RoutingMiddleware::process() - CORE/src/Routing/Middleware/RoutingMiddleware.php, line 160 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Routing\Middleware\AssetMiddleware::process() - CORE/src/Routing/Middleware/AssetMiddleware.php, line 68 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73 Cake\Error\Middleware\ErrorHandlerMiddleware::process() - CORE/src/Error/Middleware/ErrorHandlerMiddleware.php, line 119 Cake\Http\Runner::handle() - CORE/src/Http/Runner.php, line 73
"Where art, loss, and regret intersect, an unlikely, heartwarming, and violent love story unfolds."
OFFICIAL SELECTIONS -
AUDIENCE CHOICE AWARD - Best Feature
- Frameline (San Francisco)
- Tel Aviv LGBT Film Festival
- San Diego Asian Film Festival
BEST SCREENPLAY
- ASEAN Film Festival
BEST NEW DIRECTOR
- Beijing Film Festiva